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BELL 3U 




BY Lloyd J. Austin 

The telephone rings in a small 
but comfortable store-front office 
in west Knoxville, Tennessee. A mo- 
ment later a pleasant voice answers , 
"MITS - Byte 'Tronics ; how can we 
help you?" Sandra Seals, who is most 
likely to be the first voice you meet 
when you call, makes you feel at ease 
and yet gives you the assurance that 
you will get prompt and courteous 
service , no matter what your reason 
for calling. This is natural with 
her because she knows that she is 
working with well- trained and compe- 
tent people who solve computer prob- 
lems every day. 

Whether you have called for ser- 
vice, for information about the new- 
est of the line of Altair Microcompu- 
ters, for a suggestion in a software 
program, or any other of the myriad of 
questions that just come naturally, 
you will get your answers quickly and 
efficiently. If you have a question 
concerning the availability of a MITS 
product, its price, its specifications, 
or other similar information, Sandra 
will switch you over to Bruce Seals, 
who is the marketing director and 
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The People at BYTE 'TRONICS 
(X.to.,_r) Hu£tL, Bruce , £and£a, Johnny 

sales manager. If you need to know 
about the compatibility between your 
Altair 8800 and some input or output 
device, you will probably talk with 
Technical Director Hugh Huddelston 
about it. When you need a software 
program with special modifications 
and subroutines, Johnny Reed is your 
man, and he is familiar with program- 
ming on all of the several languages 
that can be used. All personnel are 
well-qualified to help you with any 
service problem because they come 
from a background of computer appli- 
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Nearing the completion of a 
highly successful tour of the South- 
eastern U.S., the MITS MOBILE "Van 
Man," Mike Hunter, reports SRO crowds 
in most cities and an enthusiastic 
response from all those participating. 
The Northeast and Midwest are up next, 
with the first stop of the fall tour 
set for Buffalo, NY on October 20. 
(for complete schedule, see page 3.) 

When the MITS MOBILE comes to 
your area, you will have a unique op- 
portunity to attend a seminar and 
slide presentation covering a wide 
range of topics including computer 
concepts, technical aspects of com- 
puters in general and computer pro- 
gramming. This is your chance to 
hear some straight talk about compu- 
ters and to ask any questions you 
may have — from the most "simple" to 
the most "advanced." Mike wants to 



show you how accessible low-cost 
computing really is. 

All the seminars are held at 
Holiday Inns. Hands-on demonstra- 
tions of a complete Altair Basic 
Language System begin at 6pm, the 
seminar itself runs from 7-10pm, and 
after 10pm more discussions or demon- 
strations for anyone who wishes to 
stay. 

Everyone present will receive a 
three-ring binder loaded with course 
material, Altair data and schematics, 
and catalogs. Reservations cost $12 
and must be made in advance by mail- 
ing your check (BankAmericard or 
MasterCharge accepted also) to MITS 
in Albuquerque. You will receive 
your admission ticket and the exact 
location of the seminar by return 
mail. 



MITS/632H Linn NE/ Albuquerque, NM 87108/ 505-265-7553 



cations and are thoroughly familiar 
with the MITS circuits in Altair, 
including the optional boards and 
peripheral devices that can be used. 

The office of Byte 'Tronics is 
located at 5604 Kingston Pike, Knox- 
ville, Tennessee - Zip Code 37919. 
Everyone is welcome to drop in at any 
time, to call on the phone at (615) 
588-8971, or to make contact by let- 
ter. The office hours are (Eastern 
Time Zone) 10AM to 10PM Monday through 
Friday and 9AM to 10PM on Saturday. 
That should allow everyone who is in- 
terested to find the office open at 
some convenient time. 

Operating as an independent dis- 
tributor, Byte' Tronics sells the full 
line of MITS products. The Altair and 
its peripherals are available in 

either kit or ready-to-use form and, 
whenever possible, on an off-the-shelf 
timetable. The prices are the same 
as those in effect at the factory, 
including special sale prices when 
they are offered. But the sale and 
delivery of the equipment is only the 
beginning of a long and fruitful re- 
lationship between every customer and 
Byte ' Tronics , because their service — 
both hardware and software— is part of 
the package that you get when you 
trade with them. Byte" 'Tronics is 
equally at home with the hobbyist or 
the professional engineer, the uni- 
versity student or the production 
line foreman, or any of the many 
other people who are finding new uses 
every day for computers-now that they 
are available and affordable. Hugh 
and Bruce and Johnny form an excel- 
lent team to furnish this client- 
supplier relationship because they 
have all been involved in every as- 
pect of the business as users, fixers, 
testers, and operators. 

Hugh's pride and joy is the 
fully stocked parts cabinet in the 
back room, with the electronic equip- 
ment that will help chase down the 
trickiest failure. His thorough 
knowledge of the purpose for each 
portion of the circuit on the board, 
together with his experience in 
troubleshooting, makes him very effi- 
Continued on -page 3- — 

ttttttttttt BULLETIN tttttfftttt 

We have discovered that many 
Signetic 2604 4K RAM's found on some 
of our 4-K Dynamic Memory Boards do 
not meet the required specifications 
for access time and refresh period. 
They are identified on the package 
as S 260M-. If you have an Altair 4-K 
Board that does not work properly 
and it has Signetic RAM's, please 
return the board along with the Sig- 
netic RAM's for complete checkout 
with replacement RAM's. We are sorry 
for the inconvenience. 

OR 505-262-1951 
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ALTAIR SERVICE BEPT. 



by David Bunnell 

RA NGE CRAIN of AD AGE 

Ranee Crain, the editorial di- 
rector of Advertising Age and Crain 
Communications, was in Albuquerque 
recently to address the local ad 
club. 

Now this isn't the type of news 
item that would normally be of inter- 
est to Altair users, but Mr. Crain 
said some very interesting things. 
For example, it is his contention 
that business has been so stifled by 
government regulations and consumer 
protection groups that managers are 
no longer able to make innovative, 
creative decisions. And the end re- 
sult of this is a lack of imaginative 
products. 

My initial reaction is that Mr. 
Crain is unaware of the electronics 
business. However, in arguing his 
position, Crain made some very con- 
vincing points about the changing 
values of consumers and the slowness 
of catch-up by industry. This is 
particularly evident in the automo- 
tive industry where Detroit has been 
slow to see the growing consumer de- 
mand for cars that are efficient, 
reliable and safe. 

According to Crain, the consumer 
code of the 60' s was "Buy, Buy, Buy." 
This is no longer in effect. Con- 
sumers are more cautious now and, 
most importantly, consumers are 
smarter . 

The MITS Philosophy 



MITS is fortunate that it is a 
relatively new corporation. Its 
philosophy is in the formulative 
stage where it still can be influ- 
enced by changing consumer attitudes 
and existing economic realities. 

For one thing, MITS is a very 
efficient corporation in that money 
isn't wasted for frills. We make 
sure that our products get the best 
engineering expertise but carpeting 
and pretty packaging are low prior- 
ities. 

MITS tries not to commit itself 
to positions that it can't keep, and 
we try to level with our customers 
when something goes wrong. Still, we 
are dictated to by the rules of real- 
ity and sometimes someone pokes us in 
the eye. And sometimes we deserve 
it. 

Consumer Responsibility 

The business ethics of the 70 's 
has so far failed to focus on the 
responsibilities of the consumer. If 
business is to adhere to new rules, 
if it is to eliminate misleading ad- 
vertising, be conscious of the envi- 



ronmental impact of its products, 
avoid making excessive profits, etc., 
what then, if anything, should the 
consumer do in return? 

Now, I don't pretend to have 
the answer to this question but 
morality is a two way street, and 
one thing that bothers me is the fact 
that a few of our customers have been 
ripping off MITS software. In viola- 
tion of their software license some 
people have been arrogantly, and I 
think foolishly, copying MITS BASIC 
for resale or to pass out to their 
freinds. 

I believe this practice is fos- 
tered by the contention that all 
software should be made part of the 
public domain. 



Now I ask you — does a musician 
have the right to collect the royalty 
on the sale of his records or does a 
writer have the right to collect the 
royalty on the sale of his books? 
Are people who copy software any dif- 
ferent than those who copy records 
and books? 

Altair BASIC is one of the most 
advanced BASICs ever written and it 
cost MITS a premium price to develop. 
Considering this and the price charged 
by many companies for software, $75 
for Altair 8K BASIC is a near steal . 
And the price of $500 for people who 
haven't purchased a minimum 8800 
system is more than reasonable. 



Since I've spouted off, I want 
to invite Altair customers to spout 
off to us if they've encountered any 
difficulties such as poor service, 
delivery, etc. Call us at 505-262- 
1951 or address your letters to the 
Altair Customer Service Department. 

We can't go about changing the 
whole MITS mode of operation every- 
time someone sends us a complaint — 
but, believe me, your letters will 
be read and seriously considered by 
someone in a high management position. 

Final Message 

Five or six years ago MITS was 
literally a garage operation not un- 
like many of the new computer hobby 
companies that have recently sprung 
up here and there. MITS was success- 
ful because it was able to deliver 
what it advertised and the success 
of these new companies will likewise 
be highly dependent on their credi- 
bility. 

Most of the people in this bus- 
iness have high ethical standards 
but watch out for the few ripoff 
artists. Don't order anything until 
you know it is "real." 
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Barbara Sims 



Hello Again! 

We now have several programs in 
our Users Group library. Descrip- 
tions of these have been published 
in our past and present newsletters. 
We are also printing prices of the 
programs in Computer Notes regularly. 
If you have a program that would be 
of general interest, please send it 
in. 

It has been a great help now 
that programs are being submitted on 
the program submission forms, however 
there has been a slight mix-up con- 
cerning the form. The coding form we 
sent you in the August issue of our 
newsletter was a sample. The sample 
should be used to make up an original 
and have it printed if you wish. 
Then, use the printed copies to send 
in to us. We can print directly from 
your program if it is handled in this 
way. However, if you merely photo- 
copy or xerox our sample, we have to 
retype the entire program. This 
slows up printing and in the end 
slows up delivery of the programs to 
you. The same is true of a typewriter 
with an old ribbon or dirty keys. If 
the type is not clear and of good 
contrast, then we have to retype the 
program for printing. This all may 
sound very particular, but we are 
trying to cut down the handling time 
so that programs sent in will immedi- 
ately be available to you, the user. 

If you'd like a simpler course 
to follow, you can order the program 
submission forms directly from MITS, 
50 copies costing $2.00. This is a 
fairly reasonable price compared to 
local printing companies. At any 
rate, keep the programs coming in. 

Our Marketing Department needs 
some help from customers also. Any- 
time you call in an order to MITS of 
any type, it is critical that you 
give the name your 8800 was ordered 
under and if at all possible, the 
8800 invoice number. This helps us 
in our record keeping between our 
accounting department, marketing de- 
partment, and service department. 

AdiosI • . 

Barbara 
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Byte 'Tronics continued 

cient. If you need an interface to 
drive some particular piece of gear, 
Hugh is most likely the one to make 
it - or 
is made. 



at least to supervise how it 



Johnny has recently been spend- 
ing some of his time at several cus- 
tomers' places of business. He has 
been writing complete software pro- 
grams to custom requirements. He is 
a good man to know when you need help, 
of course, he can operate any system, 
simple to complex, and he can spot 
an error in your program about as 
fast as the Altair can signal 
"Error." 

Johnny and Bruce are especially 
interested in a new and growing func- 
tion - the local Users Group of East 
Tennessee. All owners of an Altair 
8800 are eleigible for a year's free 
membership in this group, in keeping 
with the MITS plans. This group 
meets once a week to swap information 
and just "talk computers." Sharing 
ideas and programs is their purpose, 
and this should be helpful to all 
whether they are novice or experi- 
enced. If you would like more infor- 
mation, drop a post card to them at 
Byte ' Tronics and you will get the 
same quick and courteous response as 
if you asked 
equipment ! 



MITS 
SALES REPRESENTATIVES 

For detailed information on Altair computers and computer products, contact the 
MITS sales representative in your area. Or call our factory direct: 



MIDWEST 

Inland Associates 

13100 Manchester Road #G-25 

St. Louis, MO 63131 

314-821-3742 



MITS/6328 Linn NE 
Albuquerque, NM 87108 
505-265-7553 or 262-1952 



Inland Associates 
2310 West 75th 
Shawnee Mission, 
913-362-2366 



KS 66208 



to buy $10,000 worth of 



So if you are among those who 
are fortunate enough to already be 
an Altair user, or if you just want 
to be, either way you should get ac- 
quainted with your friends at Byte 
'Tronics because they are well qual- 
ified and anxious to help you. All 
you need is a post card, a letter, a 
phone call, or - if it is convenient - 
a visit to the office in Knoxville, 
and your world will open up in front 
of you. 



Ridgway East, Inc. 
15326 Garfield Road 
Detroit, MI 48239 
313-538-3940 

Ridgway East, Inc. 
138 Elseden Building 
Florence, KY 41042 
606-371-1269 

Ridgway East, Inc. 
173 Hawthorn Drive 
Chagrin Falls, OH 44022 
216-247-4845 



SOUTHEAST 

MITS, Inc. 

Southeastern Regional Office 

5508 NW 72nd Avenue 

Miami, FL 33166 

305-885-9388 

COL-INS-CO, Inc. 
1313 44th Street 
Orlando, FL 32809 
305-423-7615 



COL-INS-CO, Inc. 

Offices in: 

Huntsville, AL 

Largo, FL 

Atlanta, GA 

Raleigh, NC 

Call 800-327-6600 Toll-free 



WEST COAST 

REPCO 

50 East Middlefield Road 

Mountain View, CA 94043 

415-965-8581 

CT1 Data Systems 
3450 East Spring Street 
Long Beach, CA 90806 
213-426-7375 

CTS Data Systems 
8869 Balboa Avenue C 
San Diego, CA 92123 
714-292-0636 

REPCO 
PO Box 811 
Bellevue, WA 98004 
206-455-1246 



WESTERN O.S. 

BFA Corporation 

1350 Chambers Road #207 

Aurora, CO 80011 

303-344-3800 



MITS-MQBILE CARAVAN SEMINAR SCHEDULE 





GROUP A — Reservation 


Deadline October 


10, 1975 


October 


20 


Buffalo, NY 




October 30 Hartford, CT 


October 


21 


Rochester, NY 




October 31 White Plains, NY 


October 


22 


Syracuse , NY 




November 


3 New York City 


October 


24 


Albany, NY 




November 


4 Hempstead, LI, NY 


October 


27 


Boston, MA (Cambridge) 


November 


6 Plainview, LI, NY 


October 


28 


Boston, MA (Newton) 




November 


7 Hackensack , NJ 




GROUP B — Reservation 


Deadline October 


25,. 1975 


November 


10 


Allentown, PA 




December 


1 Chicago (Northbrook), IL 


November 


11 


Philadelphia, PA 




December 


2 Milwaukee, WI 


November 


13 


Baltimore, MD 




December 


4 Minneapolis , MN 


November 


14 


Washington, DC 




December 


5 Madison, WI 


November 


17 


Pittsburgh, PA 




December 


8 Indianapolis, IN 


November 


19 


Columbus , OH 




December 


9 Cincinnati, OH 


November 


20 


Cleveland, OH 




December 


10 Louisville, KY 


November 


21 


Detroit, MI 




December 


12 St. Louis, M0 


November 


24 


Kalamazoo , MI 




December 


15 Davenport , IA 


November 


25 


Chicago (Hinesdale) 


IL 


December 
December 
December 
December 


16 Des Moines, IA 

17 Omaha, NE 

19 Kansas City, MO 
21 Wichita, KS 



BFA Corporation 
395 Lawndale Drive 
Salt Lake City, GT 84115 
801-466-6522 

BFA Corporation 

4251 North Brown Avenue 

Scottsdale, AZ 85251 

602-946-4215 

BFA Corporation 

9004 Menaul Boulevard NE 

Albuquerque, NM 87112 

505-292-1212 

BFA Corporation 

Dona Ana Road, PO Box 1237 

Las Cruces, NM 88001 

505-523-0601 



NORTHEAST 

J. J. Wild, Inc. of New England 
PO Box 382 
Needham, MA 02192 
617-444-2366 

J. J. Wild, Inc. of New England 
PO Box 342 
Southbury, CT 06488 
203-264-9494 

J. J. Wild, Inc. 
73 Main Street 
Woodbridge, NJ 07095 
201-636-7780 

J. J. Wild, Inc. 

80 Second Street Pike 

Southampton, PA 18966 

215-357-6645 

J. J. Wild, Inc. 

400 Jericho Turnpike 

Jericho, NY 11753 

516-935-6600 

(for Western New York and 

Western Pennsylvania, see: 

Ridgway East, Inc. 

Chagrin Falls, OH) 



NOTE : Sales Representatives are 
geared to serving industrial custom- 
ers. Hobbyists should contact the 
factory directly or one of the MITS 
distributors. Distributors now in- 
clude Byte \ Tronics in Knoxville, Ten- 
nessee (see page 1 article) and The 
Computer Store in West Los Angeles 
(11656 Pico, phone 213-478-3168). 
Other MITS distributors will soon be 
set up across the country. Watch 
Computer Notes for all the details. 
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88-VLCT READY KEY MOD 

PROBLEM: 

Pressing "READY" key should cause one 
strobe pulse to PIO board "SBO" line, 
causing computer to output data to 
octal display. Noise from key switch 
bounce causes multiple pulses on 
"SBO" line, causing next byte entered 
to be echoed without pressing READY. 

SOLUTION : 

Change R32 from 10K to lOmeg. R32 
is across C6, the .01 pulse timing 
capacitor for the READY key. In- 
creasing R32 to lOmeg makes discharge 
time for C6 greater than 10ms, pre- 
venting keyswitch bounce. 



NOTE: 

READY key schematic is incorrect: 
R33, 100Q, shown going to Vcc is 
actually connected to ground. R31, 
47ft, shown going to ground, actually 
goes to Vcc. 

lOmeg — MITS part number 102079 



USERS' NAMES S ADDRESSES 



Frank E. Corlett 
205 Port-0-Call 
Bridgeport, TX 76026 

Keith L. Kendall 
295 E. 500 S. 
Vernal, UT 84078 

Glenn Nelson 
160 Greenway W. 
Newhyde Park, NY 11040 

Mount St. Mary's 
c/o Bill 0' Toole 
Emmitsburg, MD 21727 

Sgt. Wesley B. Isgregg 
Box 3558 C £ E Schools MCB 
29 Palms, CA 92276 
714-368-9111 DWH Ext. 6241 
AWH Ext. 7289 

Sgt. Stanley E. Herr 
13-C Copper Dr. MCB 
29 Palms, CA 92278 
714-368-3809 

Robert Beard 

2530 Hillegass Apt. 109 

Berkeley, CA 94704 

Tod Rapp 
129 Park Dr. 
Xenia, OH 45385 
Business 513-372-8294 
Home 513-372-8445 



To be featured on cover of November, 1975 Popular Electronics. 



SNEAK 




In January of 1975, MITS stunned the computer world with the announce- 
ment of the Altair 8800 general purpose computer that sells for $439 in kit form 
and $621 assembled. 

In October of 1975, MITS will announce a complete computer built around 
the 6800 MPU available from Motorola and AMI. 

This computer will come with an MPU board that has IK RAM, built-in I/O that 
can be configured three ways, and provision for IK ROM or PROM. It will have 
power supply and be sold with front panel control board in an 11" x 11" x 
4 11/16" case for $293 in kit form and $420 assembled. 

The MPU Board — ideal for dedicated control applications— will be marketed 
for $180 in kit form and $275 assembled. . 



Jim Fisk-WB9N1V 
4116 Euclid Ave. 
Ft. Wayne, IN 46806 
219-745-0359 

Michael A. Enkelis 
9924 S.W. 31st Ave. 
Portland, OR 97219 
503-246-4614 

Stephen E. Clark 
2099 Powder Horn Dr. 

Clearwater, FL 33528 



Bruce Segal 
64 Summit Crescent 
Westmount PQ 
Canada H3Y 1L6 



C. A. Kirkpatrick 
2041 San Sebastian Ct. 
Apt. 70 

Houston, TX 77058 

Richard Hole-WA8TSY 
Gerber Products Company 
Fremont, MI 49412 
Business 616-928-2692 
Home 616-652-6884 

Gary Tack 
P.O. Box 866 
Corrales, NM 87048 

Matthew W. Smith 
4355 S. High St. 
Englewood, CO 80110 

Gary S. Trent 
Route 5, Box 900 
Space 17 
Orange, TX 77630 

John E. Kabat 
"Universe Unlimited" 

User ' s Group 
11918 Forrest Ave. 
Cleveland, OH 44120 
Business 216-781-9400 Ext. 
Home 216-795-2565 

D. Minott 

352 Arkansas Dr. 
Valley Stream, NY 11580 

Donald C. Schertz 
764 Toyon Dr. 
Monterey, CA 93940 

Ivan Wampfler 
7861 Old River Rd. 
Rockford, IL 61103 
815-633-4757 



Richard Bushick-WA3PW0 
418 Brian Ct. 

Mechanicsburg , PA 17055 

John Rabenaldt 
1301 N. Jackson #24 
Odessa, TX 79761 
915-337-6931 



55 



For complete details, see November's Popular Electronics. 
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Au2 Software Contest Winners Announced 



by Paul Allen and Bill Gates 



This month nine programs and 
nine subroutines were added to the 
Library. 

The ultimate in memory clears 
seems to have been written by Ward 
Christensen (#731751). 

"I have been using the follow- 
ing 'program' to clear memory in my 
Altair since the first week I had it. 
It clears all of memory except byte 

0, and leaves the address in location 

1. It works because the Altair seems 
to have the stack pointer at location 
when powered up. At worst, it 
would have to be run twice." 



0000 
0001 



063 
307 



INX SP 
RST 



The winning major program this 
month is a quadruple byte integer 
manipulation package by Steve Phil- 
lips (see below). In second place 
is R. J. Walker's PI0 BASIC or Pack- 
age I loader. Third place goes to 
John Trautschold for his mutiplica- 
tion program for floating point num- 
bers. 

In the subroutine category, 
first place goes to Donald Tork for 
his table search routine. Second 
place goes to Jonathan Griffitts for 
a subroutine which may be used to 
display the A register in the status 
lights for one second, which could 
be useful as a debugging tool. 

PROGRAMS 

#92751 

Author: Dean B. McDaniel 

Length: 23 bytes 

"Object: To kill the rotating bit. 

If you miss the lit bit another one 

at that sense switch position will 

turn on, now leaving you two bits to 

destroy. " 

#815751 

Author: John Trautschold 

Length: 476 bytes 

Multiplies a 12-digit floating point 

number times an 8-digit floating 

point number. 

#88751 

Author: Charlie Shields 

Length: 22 bytes 

Outputs l's to an I/O port a selected 

percentage of the time. Outputs O's 

the rest of the time. 

#829751 

Author: R. J. Walker 

Length: 57 bytes 

Loads checksummed 4K or 8K Altair 

BASIC from an unmodified PI0 board. 



#825751 

Author: Robert L. Berg 

Length: 34 bytes 

Simple memory test. Halts when finds 

a bad location. 

#818752 

Author: Steve Phillips 
Length: 477 bytes 

Quadruple byte signed integer manip- 
ulation package. Addition, subtrac- 
tion, multiplication, division as 
well as sign and zero value testing 
and other useful routines. 

#813751 

Author: John S. Robison 
Length: 277 bytes 

Tests ACR interface by comparing the 
record line output to the input from 
the monitor playback output from 
those tape machines which have moni- 
tor capability. 

#94751 

Author: Carl Swift 

Length: 15 and 11 statements 

BASIC programs to dump/store memory 

in octal using Altair BASIC'S PEEK 

and POKE statements. 



SUBROUTINES 

#825754 

Author: Dr. Jack W. Crenshaw 

Length: 16 bytes 

ASCII/HEX — HEX/ASCII conversion 

subroutines. 

#818751 

Author: Jonathan Griffitts 
Length: 23 bytes 

Displays the contents of the accumu- 
lator in the address lights. 

#811753 

Author: Thomas D. Thomas 

Length: 19 bytes 

Adds a quadruple byte integer pointed 

to by [H,L] to registers [B,C,D,E]. 

#813752 

Author: David Nowak 
Length: 4 bytes 

Subroutine to do a relative jump us- 
ing a displacement in [D,E]. Could 
be used as an RST. 



RJMP : XTHL 



DAD D 
XTHL 



RET 



;Get return address in 

;[H,L] 

;Save [H,L] on stack 

;Add on displacement 

;Save back return 

jaddress and restore 

j[H,L] 

;Do relative branch 



(Author's note: How about an RST 
that does a relative branch on the 
signed byte that follows the RST? 
Anyone?) 



SOFTWAR 




#84753 

Author: Nilton G. Gimenes 

Length: 33 bytes 

Converts a 2-byte unsigned number 

into 6 individual octal digits in 

consecutive memory locations. 

#811751 

Author: Donald S. Tork 

Length: 74 bytes 

Searches a table of up to 255 entries 

of up to 255 byte strings for a match 

on the search string, which may also 

be up to 255 bytes long. 

#99751 

Author: Gary Tack 

Length: 21 and 27 bytes 

Routines to add/subtract two 16- 

digit BCD numbers. 

#84752 

Author: Nilton G. Gimenes 
Length: 28 bytes 

Translates six octal digits in con- 
secutive locations in memory to a 
double byte value in [D,E]. 

#84751 

Author: Nilton G. Gimenes 
Length: 15 bytes for each routine 
Octal/ASCII -- ASCII/octal conver- 
sion routines for octal digits/ 
characters stored in six sequential 
memory locations. 



NOTES ON PACKAGE I 

By Taut Wa.6mu.nd 

One major point that was not 
covered in the Package I documenta- 
tion was the stack. There are 30 
bytes of stack available for the user 
at all times. If a program needs 
more stack space than that , it should 
set up a stack of its own. 

If a program should infinite 
loop, stop your machine and restart 
the monitor by examining location 
and pressing the run switch. 

Release Two of Package I will be 
ready in early October. New features 
include tab stops to help make your 
program listings more readable and a 
highly improved editor. Two new com- 
mands have been added and all old 
editing commands have been improved. 

FIND - The find command searches 
for a given string until a line con- 
taining it is found. The entire line 
it is in is then printed. 

ALTER - Allows altering charac- 
ters within a line. This command al- 
lows lines to be changed without hav- 
ing to replace them. 

The insert and delete commands 
have been improved so that you can 
now insert blocks of lines and delete 
blocks of lines. 
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CALL INCHR ;Get a character from the terminal. 
CPI 15Q ;Was it a carriage return? 
JZ ENDLIN ;If so, end of input line. 



Of course, the stack pointer 
must be set up pointing to an area of 
memory set aside for use by subrou- 
tine calls and PUSH/POP and other 
stack manipulations. This is most 
easily done as follows (this code is 
usually placed at the start of your 
program ) : 



START i 



LXI 



DS 



SP, STACK 



20 



STACK: 



More information on how to use 
the stack will be provided in Bill 
Gates' software article next month. 

A corresponding character (byte) 
output subroutine for an old (REV 0) 
SIO board is listed below. The byte 
to be output is in the A register: 



OUTCHR: 

OUTLP : 



Here are a few items of 
interest : 

# 

1. The current version of BASIC 
being shipped is 3.1. The only 
change is that in the 8K version the 
array access is now significantly 
faster. 

2. The FORTRAN cross assembler is 
now available on paper tape as well 
as a listing. The paper tape and 
listing together cost $30, while the 
listing alone costs $15. If you wish 
to obtain the cross assembler in an- 
other form, call the software depart- 
ment at the factory. The program 
order number is 521751. 

3. There will be two versions of 
Extended BASIC; one that runs with 
the disk and one that runs without 
it. We are assuming that all orders 
placed are for the disk version so 

if you want the "stand-alone" version 
of Extended BASIC, drop us a line to 
let us know. The advantage of the 
stand-alone version is that it is 2K 
bytes smaller. 

Programmed I/O 

The coding technique for data 
input and output in which the CPU 
waits for completion of the I/O op- 
eration is usually termed "programmed 
I/O." This is by far the easiest and 
most common way of writing input and 
output subroutines for the Altair, 
and is used by BASIC and the Package 
I software. 

There are usually two subrou- 
tines for each device. One that in- 
puts a character from the device and 
one that outputs a character to the 
device. The input routine (INCHR) 
waits for the device's input buffer 
full flag to be set and then reads 
the character. On the Altair, the 
device status is in the input side of 
the lower I/O channel, and the data 
is read from that channel +1. Assum- 
ing we will return the byte read from 
the device in the A register, the 
code is as follows (for an old SIOC 
board — character ready bit in bit 5): 



INCHR: IN INCHN ; where ICHN is the input channel 

ANI 40Q ;TEST BIT 5=0 (Q means octal). The mask M-OQ is 

;"anded" with the device status in the A register. 
;The mask (M-OQ) selects only bit 5. 

JZ INCHR ;If no input data ready., loop. 

IN INCHN+1 ;Read the input byte. 

RET ; Return from the subroutine. 

Note that the input character 
routine is a "subroutine" that could 
be called many different places in a 
program by using a CALL instruction, 
i.e. 



;set aside 20 locations (10 levels) of stack space 



PUSH PSW 
IN INCHN 
ANI 2Q 
JZ OUTLP 

POP PSW 



;Save the A register on the stack. 

;Read the device status into the A register. 

;See if bit 1 is = 0. 

;If it is, keep waiting for the terminal to finish 
; printing. 

;Get back the saved output byte. 



OUT INCHN + 1 ;Now output the byte to the terminal. 



RET 



; Return from subroutine. 



REMINDER: 






Users of BASIC and Package I 


should 


address their console 1/0 boards 


(SIOA, SIOC) for 


I/O port 0. 


The 


ACR board should 


be address 


for I/O 


port 6 . 







Often it is desirable to echo 
the character read from a terminal ' s 
keyboard immediately back to the ter- 
minal. The easiest way to do this is 
to insert 



INECHO: CALL INCHR 

right before the OUTCHR routine and 
then call INECHO instead of INCHR. 
If we knew we were always going to 
echo the input character back to the 
terminal, we could have the input 
character subroutine (INCHR) "fall 
into" the output character routine 
(OUTCHR). This may be done by plac- 
ing INCHR directly ahead of OUTCHR 
and also removing the RET at the end 
of INCHR so an "OUTCHR" will always 
be performed when INCHR is called. 
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Slight modifications must be 
made to these routines if we want to 
use REV 1 or modified REV serial 
I/O boards. In these boards, the 
character ready bit is in bit of 
the status byte, and the character 
done (sent) bit is in bit 7. Also, 
the bits are "active low," that is, 
a 1 means the bit is false and a 
zero means the bit is true, which is 
just the opposite of the way the bits 
were set on the REV board used in 
the previous examples. We could test 
bits by using an AND immediate in- 
struction as before (i.e. replace the 
ANI 4-OQ in INCHR with an ANI 1Q and 
the ANI 2Q to an ANI 200Q) and chang- 
ing the JZ's to JNZ's. However since 
the status bits are in the least and 
most significant bits in the status 
byte, we can conveniently test them 
by using the rotate instruction to 
move the bit in question into the 
carry flag and then using a JNC in- 
struction to loop: 

INCHR: IN ICHN ;Read status 

RAR -, Character ready? 

JC INCHR ;If not, loop 

IN INCHN+1 ;Read character 

RET ; Return 

OUTCHR: PUSH PSW ;Save character 
OUTLP: IN ICHN ;Read status 
RAL ;Test bit 7 
JC OUTLP 
POP PSW ;Get character 

;back in A 
OUT INCHN+1; Send it to 

; terminal 
RET ;A11 done, return 

Using rotates instead of ANIs 
saves one byte in each routine. Re- 
member : taking care to save each 
byte you can will make long programs 
significantly shorter and faster. 

PIO boards (often used for SWTPC 
TVTs) have the status bits "active 
low" like REV 1 SIO boards, but the 
status bits are in different posi- 
tions: character ready is bit 1 and 
character done is bit 0, so: 
INCHR: IN INCHN 

ANI 2Q 

JNZ INCHR 

IN INCHN+1 

RET 

OUTCHR: PUSH PSW 
OUTLP: IN ICHN 

RAR 

JNC OUTLP 

POP PSW 

OUT INCHN+1 

RET 
If you are confused by the use 
of "masks," here is an explanation. 
If we want to make a jump on only one 
bit of the A register, we "and" a 
mask with that bit on with A. The 
result of the AND will be zero if 
that bit was zero, and non-zero if 
the bit was one. Here is a table of 
bit. masks (in octal) for each bit 
position: 



BIT 


MASK 





1 


1 


2 


2 


4 


3 


10 


4 


20 


5 


4-0 


6 


100 


7 


200 



(usually use RAR to test) 



200 (usually use RAL to test) 



Note that bits and 7 take 
fewer bytes to test than the rest 
because they can be rotated into the 
carry status bit as mentioned earlier. 

It is often very useful to use 
bit testing and setting in a program. 
Suppose you are writing an assembler 
and you want to remember if you have 
seen any colons or commas on a line. 
You could use one bit in a register 
to flag the fact you had seen a colon 
and another bit to flag whether you 
had seen a comma; and you could use 
the other six bits of the register 
for six other flags. Suppose the 
flags were kept in the B register. 
Then, to set a flag (if bit=l means 
set): 



MOV A,B ;Get flag register in A 



DRI 2 



;Mark colon seen (bit 1) 



MOV B,A ;Save flags back 

To reset a flag: 

MOV A,B ;Get flag register in A 

ANI 375 ;377-2 

; Reset colon flag (bit 1) 

MOV B,A ;Save flags back 

To test two flags: 

MOV A,B ;Get flag register 

ANI 12Q ;Test both bits 3 6 1 
; (colon and comma) 

JZ NETHER ;Jump to NETHER if both 
; flags = 

JNZ ONEFLG ;Jump to ONEFLG if one 
;or both of two flags 
;set. 

To complement (invert) a flag (reset 
it if set, set it if reset): 

MOV A,B ;Get flag register 

XRI 2 ;Flip (complement) bit 1 

MOV B,A ;Save flags back 

Final Note: 

If you'd like us to cover some 
particular technique or coding prac- 
tice in detail, let us know. 



by Bill Gates 



Though the most difficult and 
enjoyable part of writing a program 
is the design of data structures and 
program flow, it is also important to 
use the least number of instructions 
possible to perform each function in 
a program. For instance: 



CALL SUB1 

RET 

JMP SUB1 



should be replaced by 



unless something fairly 
tricky is being done 
with return addresses. The JMP is 
faster, takes one less byte, and 
uses no stack space. An instruction 
book on programming the 8008 ignores 
this simple fact! 

JMPs should be avoided wherever 
possible. By rearranging code you 
can often avoid having an uncondi- 
tional JMP by falling into the rou- 
tine you were JMPing to. 

The beginning programmer will 
use lots of SHLDs, LHLDs, STAs and 
LDAs when they are not necessary. 
The stack can be used to save tem- 
porary values in most cases. SHLDs, 
LHLDs, LDAs and STAs should only be 
used for values referenced in many 
different contexts within a program, 
i.e. an I/O parameter or the current 
line number. 

A good technique for familiar- 
izing yourself with the instruction 
set is to go out of your way to use 
every instruction at least once (ex- 
cept perhaps DAA). Go through the 
instruction set from time to time 
and look closely at the instructions 
you seem to use very rarely. With 
few exceptions (DAA, SPHL) all the 
instructions can be used to advan- 
tage, even in small programs. One 
of the most overlooked instructions 
is XTHL. When all the accumulators 
have values that must be saved and a 
value needs to be taken off the 
stack, XTHL is the only instruction 
that can be used. 



Example: ;Exchange [B,C] with [H,L] 

PUSH B ;put [B,C] on the stack 

XTHL ;[H,L] = top stack entry = 
[B,C] 

;[H,L] goes on the stack 

POP B ;[B,C] = original [H,L] 

Sometimes the simple way of do- 
ing things is the best. PUSH B/POP D 
may seem like a tricky way of setting 
[D S E] = [B,C], but the obvious se- 
quence MOV D s B/M0V E,C is much faster. 
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Some tricks involve instruction 
sequences which at first sight seem 
meaningless. For instance: SUB A 
or XRA A. Subtracting A from itself 
or exclusive-oring A with itself are 
the only one-byte ways of setting 
A=0. MVI A s must still be used if 
the condition codes need to be pre- 
served, but this is rare. 

ADC A is equivalent to RAL, ex- 
cept it affects all the condition 
codes. SBB A sets A=0 if carry is 
off and A=377 if carry is on. The 
routine below uses this fact to con- 
vert A as a signed integer to a dou- 
ble byte signed integer in [H,L]: 

MOV L,A j setup the low order 
|now the sign must be 
I "extended" by setting H=0 
j if A=>0 and H=377 otherwise 

RAL ;Carry = 1 if A<0 
; Carry = if A=>0 

SBB A ;A=0 if old A was =>0 
|A=377 if old A was <0 

MOV H,A ; setup the high order 



The sequence: INR E 
DCR E 
doesn't modify any values, but it 
does set the condition codes .(-except 
carry) depending on what is in E. If 
E is being used as a flag to indicate, 
say, whether or not a decimal point 
has been seen, the zero flag is set 
up to do a conditional JMP. 

The subject of good decimal 
print routines has been discussed 
extensively in the Alt air Software 
Department this week. This routine 
is one of the four or five I wrote 
this week — each with its own advan- 
tages and disadvantages. This one 
is fairly tricky, in that it takes a 
little bit of looking at to under- 
stand. 



#1 



Print the binary unsigned number 
in [H,L] in decimal, suppressing 
leading zeros 

24 bytes (25 if saves D,E) 

ON RETURN: 

A = last digit in ASCII 

B,D = 255 (all constants in 

decimal) 

C,E = last digit -10 

H,L = 

Uses up to 18 bytes of stack 
Total compute time up to 85 
milliseconds 

IDEA: calculate a digit, save it 
on the stack, and call the 
digit calculator to calcu- 
late and print higher order 
digits, pop the digit off 
and print it. 



DECOUT: LXI B, -10 
GETDIG: MOV D,B 
MOV E,B 
LOOPSB: DAD B 

INX D 

JC LOOPSB 

PUSH H 



XCHG 
MOV A,H 
ORA L 
CNZ GETDIG 

MVI A, "0" + 10 

POP B 

ADD C 

JMP OUTCHR 



CALL here 

[D,E] = -1 

since B = 255 

Subtract 10 from [H,L] until [H,L] < 10. Carry 

won't be set by the last DAD when [H,L] < 10. 

increment the count 

loop subtracting 

[L] = current digit -10 

Save the current digit on the stack. Change to 

XTHL and add PUSH D at GETDIG to save [D,E]. 

[H,L] = old [H,L]/10 

Set zero flag if [H,L] = 

If not zero, print the higher order digits and 
then return here to print this digit. 
A = constant to add to digit 
pop the digit into C 
A = ASCII of digit 

Jump to the routine to print A and return. If 
; OUTCHR is located next, the JMP can be eliminated. 



Parity is used as a check to 
detect errors in data transmission. 
Each data word is given an additional 
bit which is set to 1 if there are 
an odd number of l's in the data and 
otherwise. When the data is re- 
ceived the parity bit is checked to 
make sure it is set properly. Thus, 
if you are reading a 7-bit ASCII 
paper tape with the 8th bit used for 
parity, the parity of the entire 8 
bits should be even. 

The reason I first thought about 
a parity routine for the 8080 is 
that the parity condition code and 
all the instructions related to it 
(JPO, JPE, RPE, RP0 s CPO, CPE) are 
seldom used. I wondered how diffi- 
cult it would be to calculate parity 
if the parity flag were removed. A 
user-settable flag would be much 
more useful than the parity flag. 
BASIC uses the parity flag in only 
about eight places, and all of these 
are special tricks. Here is the 
smallest parity routine I've been 
able to write: 

;Enter with number in A. 10 bytes. 
;0n exit, A=0 and all the other reg- 
isters are preserved. 
; Carry is set depending on A's 
^parity. 

;Enter at ODDPAR for carry on to 
;mean odd parity. 



WHICH I/O INTERFACE FOR YOU? 

1. SI0C- 

For Teletypes* or other 20mA cur- 
rent loop asynchronous terminals 
up to 19,200 baud. (5-8 data 
bits) 

2. SI0A- 

For asynchronous RS-232 CRTs or 
other terminals of data rates up 
to 19,200 baud. (5-8 data bits) 

3. SI0B- 

Same as SI0A and SI0C except 
output and input are TTL compat- 
ible levels. 

4. PI0- 

For bidirectional transmission 
of bytes at speeds up to approx- 
imately 25,000 bytes/sec (200,000 
baud). Eight lines (1 byte) in 
and out plus "handshaking." All 
lines standard TTL compatible. 
Most commonly used for SWTPC-TVTs 
or equivalent, custom A/D-D/A 
interfaces, computer to computer 
interfaces, numerical control 
applications. 

^Teletype is a registered trademark 
of the Teletype Corporation. 



ODDPAR: 



ADD A 

RZ 

JNC ODDPAR 



;Move a bit of A into carry. 

;If all bits added into carry, return. 

;If no bit moved into carry, rotate more. 



; enter at EVNPAR for carry on to 
;mean even parity 



EVNPAR: 



ADI 200 



JMP ODDPAR 



; Complement the parity of the remaining bits 



; Rotate more. 



I said last month I would ex- 
plain the bootstrap loader but I've 
decided that should wait until next 
month when I explain the basics of 
the stack. 

Also next month: multiprecision 
arithmetic, and more interesting 
subroutines. 



Package 1 continued — 

Another large improvement was 
made in line number specifications. 
In addition to being able to say 
Print line 5 (P5) you now can also 
say print the current line (P.) or 
print the current line plus or minus 
a constant (P. -6, .+6). 

Also, typing escape will print 
the previous line, and line feed will 
print the line after the current one. 



